GtkStyleContext: Add gtk_style_context_invalidate().
authorCarlos Garnacho <carlosg@gnome.org>
Sat, 11 Sep 2010 10:18:26 +0000 (12:18 +0200)
committerCarlos Garnacho <carlosg@gnome.org>
Sat, 4 Dec 2010 14:38:12 +0000 (15:38 +0100)
This function will regenerate all styling information.

gtk/gtkstylecontext.c
gtk/gtkstylecontext.h

index 148dbd4594f57d409a9ee9a6d2a865286560fdd2..c738e910e7da45dcb5a42990f226a230b983b6c0 100644 (file)
@@ -97,7 +97,9 @@ struct GtkStyleContextPrivate
 
   GSList *animation_regions;
   GSList *animations;
-  gboolean animations_invalidated;
+
+  guint animations_invalidated : 1;
+  guint invalidating_context : 1;
 
   GtkThemingEngine *theming_engine;
 
@@ -110,6 +112,13 @@ enum {
   PROP_DIRECTION
 };
 
+enum {
+  CHANGED,
+  LAST_SIGNAL
+};
+
+guint signals[LAST_SIGNAL] = { 0 };
+
 static void gtk_style_context_finalize (GObject *object);
 
 static void gtk_style_context_impl_set_property (GObject      *object,
@@ -133,6 +142,15 @@ gtk_style_context_class_init (GtkStyleContextClass *klass)
   object_class->set_property = gtk_style_context_impl_set_property;
   object_class->get_property = gtk_style_context_impl_get_property;
 
+  signals[CHANGED] =
+    g_signal_new (I_("changed"),
+                 G_TYPE_FROM_CLASS (object_class),
+                 G_SIGNAL_RUN_FIRST,
+                 G_STRUCT_OFFSET (GtkStyleContextClass, changed),
+                 NULL, NULL,
+                  g_cclosure_marshal_VOID__VOID,
+                  G_TYPE_NONE, 0);
+
   g_object_class_install_property (object_class,
                                   PROP_SCREEN,
                                   g_param_spec_object ("screen",
@@ -1798,6 +1816,33 @@ store_animation_region (GtkStyleContext *context,
     }
 }
 
+void
+gtk_style_context_invalidate (GtkStyleContext *context)
+{
+  GtkStyleContextPrivate *priv;
+
+  g_return_if_fail (GTK_IS_STYLE_CONTEXT (context));
+
+  priv = context->priv;
+
+  /* Avoid reentrancy */
+  if (priv->invalidating_context)
+    return;
+
+  if (!priv->widget_path)
+    return;
+
+  priv->invalidating_context = TRUE;
+
+  rebuild_properties (context);
+  clear_property_cache (context);
+  rebuild_icon_factories (context);
+
+  g_signal_emit (context, signals[CHANGED], 0);
+
+  priv->invalidating_context = FALSE;
+}
+
 /* Paint methods */
 void
 gtk_render_check (GtkStyleContext *context,
index 020368c0a055248a0a871d45cf0caf07cc8cbbad..fba6028f50fc3d6bfed22209897bc92f84c348b0 100644 (file)
@@ -45,6 +45,8 @@ struct GtkStyleContext
 struct GtkStyleContextClass
 {
   GObjectClass parent_class;
+
+  void (* changed) (GtkStyleContext *context);
 };
 
 GType gtk_style_context_get_type (void) G_GNUC_CONST;
@@ -160,6 +162,9 @@ void gtk_style_context_state_transition_update (GtkStyleContext *context,
 void gtk_style_context_state_transition_stop   (GtkStyleContext *context,
                                                 gpointer         identifier);
 
+void gtk_style_context_invalidate (GtkStyleContext *context);
+
+
 /* Paint methods */
 void gtk_render_check (GtkStyleContext *context,
                        cairo_t         *cr,